package com.ctsi.ssdc.service;

import com.ctsi.ssdc.entity.Excel11;
import com.ctsi.ssdc.entity.FixedInvestment;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.transaction.annotation.Transactional;

import java.util.Date;
import java.util.List;
import java.util.concurrent.Future;

/**
 * 11基础表投资（工投基础）(Excel11)表服务接口
 *
 * @author makejava
 * @since 2023-02-21 19:44:40
 */
@Transactional
public interface Excel11Service {

    /**
     * 通过ID查询单条数据
     *
     * @param id 主键
     * @return 实例对象
     */
    Excel11 queryById(Long id);

    /**
     * 分页查询
     *
     * @param excel11 筛选条件
     * @param pageRequest      分页对象
     * @return 查询结果
     */
    Page<Excel11> queryByPage(Excel11 excel11, PageRequest pageRequest);

    /**
     * 新增数据
     *
     * @param excel11 实例对象
     * @return 实例对象
     */
    Excel11 insert(Excel11 excel11);

    /**
     * 修改数据
     *
     * @param excel11 实例对象
     * @return 实例对象
     */
    Excel11 update(Excel11 excel11);

    /**
     * 通过主键删除数据
     *
     * @param id 主键
     * @return 是否成功
     */
    boolean deleteById(Long id);


    /**
     * 批量添加
     * @param list
     * @return
     */
    boolean insertBatch(List<Excel11> list);

    /**
     * 获取工业投资当月 + 累计 + 累计同比
     * @param year
     * @param month
     * @return
     */
    FixedInvestment getIndustrialInvestmentInfo(String year, String month);

    /**
     * 获取基础设施项目投资当月 + 累计 + 累计同比
     * @param year
     * @param month
     * @return
     */
    FixedInvestment getBasicInvestmentInfo(String year, String month);

    /**
     * 全社会固定资产投资当月 + 累计 + 累计同比
     * @param year
     * @param month
     * @return
     */
    FixedInvestment getSocialFixedInvestmentInfo(String year, String month);


    /**
     * 根据日期删除
     * @param date
     * @return 是否成功
     */
    boolean removeByDate(Date date);


}
